Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add initial take at a more formalized JEP process #14

Closed
wants to merge 1 commit into from

Conversation

jamesls
Copy link
Member

@jamesls jamesls commented May 24, 2022

I'm sure this will evolve over time so I wanted to start
with as lightweight a process as possible.

I will also backfill the existing JEPs to this repo in a separate PR.

Unresolved Issues

There's still a few things we need to figure out in the overall process, but I don't think it needs to block reviewing JEPs.

  • Specification versioning. We need to figure out how we want to version the spec. We could treat it like semver where every change to the spec (i.e a JEP approval) results in a version bump to the spec. We should also decide on what version we should use for the version of the spec as it exists today. We may also want to batch updates so that we bump versions of the spec based on groups of features being accepted.
  • Tracking library compliance. We could restructure the jmespath.tests to be based on JEPs (need to figure out if we can backfill this). That would mean we track supported compliance levels based on JEPs, and we should be able to automate tracking compliance levels. My main concern with this is that it may be too granular. As we add more and more JEPs, it might be hard to track which groups of features a library supports.

Interested in hearing other ideas people may have.

I'm sure this will evolve over time so I wanted to start
with as lightweight a process as possible.
@innovate-invent
Copy link

innovate-invent commented May 24, 2022

While refactoring the spec repo I changed the format of the JEP https://github.com/jmespath-community/jmespath.spec/blob/efbdbd9ee3292285b65f1f8b38fbcf56760087fa/TEMPLATE.md?plain=1#L8
The semver level change is declared in the JEP, then when it is accepted the version is incremented at that level conceptually but there is no actual version tag until there are enough changes to justify it. Once the repo has hit some sort of milestone, it is tagged with the current semver version. The version tags are not necessarily contiguous. The tags are to provide implementers reasonable milestone targets when choosing a point to update their implementations, without preventing implementers from going ahead and keeping up with the bleeding edge of the spec.

I also significantly reworked the way tests are tracked in the spec repo. The tests were changed to YAML format to make them more readable and leverage YAML features to de-duplicate data. The concept of a 'suite' in the original testing structure was done away with as it was more just a means of de-duplicating data. The function tests were split out into separate YAML documents, one for each function. Along with the specific tests, these documents contain descriptions of the functions signature in a structured format that lends itself to decoupling the presentation in the website and meta-programming. Ultimately the idea was that if an implementation wanted to be included in the list it would need to provide a CLI that would allow running the compliance tests against.

I combined the tests repo, the JEPs and the spec all into one repo so that changes are tracked in the same commit history. The expectation was that a JEP would accompany all of the required tests, grammar changes, and documentation all in the same PR.

@springcomp
Copy link
Contributor

In our effort with @innovate-invent we settled on using version number 2015-09-05-9e8d0e3 for the currently widely known version of JMESPath. It tracks the date and SHA1 commit identifier of the last commit that updated the spec in this repository.

Our plan was to go with semantic versioning from there onwards.

@jamesls
Copy link
Member Author

jamesls commented May 25, 2022

The semver level change is declared in the JEP, then when it is accepted the version is incremented at that level conceptually but there is no actual version tag until there are enough changes to justify it. Once the repo has hit some sort of milestone, it is tagged with the current semver version. The version tags are not necessarily contiguous. The tags are to provide implementers reasonable milestone targets when choosing a point to update their implementations, without preventing implementers from going ahead and keeping up with the bleeding edge of the spec.

I like the idea, couple of questions:

  1. What would determine a milestone for tagging the current semver version? The breadth of changes? Amount of time?
  2. In the time between a JEP being accepted/merged until the time the semver is bumped, would the JEP be considered part of the spec (i.e are library authors free to implement the JEP)?

I also significantly reworked the way tests are tracked in the spec repo.

It's an interesting idea that I'd like to look over more. One concern I have is that many of the existing implementations have test runners for the existing test suite format, and I'm hesitant to require them to rewrite their runner unless there's significant benefit in doing so (not that there isn't, haven't had a chance to look them over yet).

@jamesls
Copy link
Member Author

jamesls commented May 25, 2022

Our plan was to go with semantic versioning from there onwards.

To clarify, are you saying that the 2015-09-05-9e8d0e3 style version is intended to be temporary until the switch to semver?

@springcomp
Copy link
Contributor

Our plan was to go with semantic versioning from there onwards.

To clarify, are you saying that the 2015-09-05-9e8d0e3 style version is intended to be temporary until the switch to semver?

When we debated this, I was leaning towards using this style going forward but we landed on the consensus that semantic versioning was better in the long run. Since no version 1.0 was ever released, I also wanted a clear track from where we diverged from the official repository. Hence, we would have kept the date-style versioning scheme only temporarily until the next version 1.0 which would have been our first release.

@innovate-invent
Copy link

  • What would determine a milestone for tagging the current semver version? The breadth of changes? Amount of time?

I hadn't gotten that far. I was thinking of just kina winging it and tagging a version any time an "important" JEP was merged.
I expect that JEPs would somewhat (but not necessarily) accumulate while being drafted and would be a part of some sort of milestone.

  • In the time between a JEP being accepted/merged until the time the semver is bumped, would the JEP be considered part of the spec (i.e are library authors free to implement the JEP)?

The semver is incremented by a JEP being merged. I it is occurring to me that most JEPs would be a MINOR change so I am not too sure how to actually work this. I think the MAJOR would be incremented once per batch of breaking changes rather than per breaking JEP. Perhaps the same should be done for the MINOR as well.

One concern I have is that many of the existing implementations have test runners for the existing test suite format

We wanted to push for implementations to provide a CLI rather than their own test pipeline. That said, I can very easily provide a script that will convert the existing tests to the original format. They can clone the repo and run this script to generate the json on demand. I don't expect it to be too difficult to swap to a yaml parser from a json parser for their test suites though.

@jamesls jamesls closed this in 4ea9cb4 Mar 17, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants